import axios from 'axios'
import Vue from 'vue'
import Vuex from 'vuex'
// 1. 导入包
import createPersistedState from 'vuex-persistedstate'
Vue.use(Vuex)

export default new Vuex.Store({
  // 2.配置为 vuex 的插件
  plugins: [createPersistedState()],
  state: {
    //   用来存储登录成功后，得到的token
    token: '',
    // 2.定义用户信息对象
    userInfo: {}
  },
  mutations: {
    //   2.更新 token 的 mutation 函数
    updateToken (state, newToken) {
      state.token = newToken
    },
    // 3.更新用户信息
    updateUserInfo (state, info) {
      state.userInfo = info
    }
  },
  actions: {
    //   3.定义初始化用户基本信息的 action 函数
    async initUserInfo (ctx) {
      const { data: res } = await axios.get('/my/userinfo')
      if (res.code === 0) {
        ctx.commit('updateUserInfo', res.data)
      }
    }
  }
})
